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(57) Methods, systems, and software for installing 
and operating selected software applications on a client 
computer that is in communication with a server com- 
puter on a computer network is described. In one as- 
pect, a method for installing and operating a selected 
software application on a client computer that is in com- 
munication with a server computer across a computer 
network. In one embodiment, browser software is pro- 
vided on the client computer that includes a browser us- 
er interface and is effective to identity and download se- 
lected software applications from the server onto the cli- 
ent computer for execution thereby. A data transfer com- 
munication link is established between the client and 
server computers across the network, a desired soft- 
ware application is selected using the browser, and the 



desired software application is transmitted across the 
network from the server to the client. The browser user 
interface is then transmuted into the user interface of 
the desired application to altow operatk>n of the down- 
loaded software applicatbn using the transmuted 
browser user interface. Using the methods, systems, 
and software described herein, software can be distrib- 
uted to client computers without the installation and oth- 
er management difficulties common with managing soft- 
ware on multiple computer systems. More importantly, 
the methods, systems, and apparatus provided by the 
present invention allow for the distribution of software 
that is platform-independent; thereby freeing network 
and system admin istrators-and users-from the frustra- 
tions and difficulties created by the need to manage var- 
ious platform-dependent versions of software. 
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Description 

BACKGROUND OF THE INVENTION 

1 . The Field of the Invention s 

The present invention relates to network computing 
and, more specifically, to the transmission and operation 
of software distributed across computer networks. Still 
nrore specifically, the present rivention includes a meth- io 
od, apparatus, and software for dynamically rrKxjrfying 
computer interfaces so that users can access and op- 
erate software distributed across a computer network. 

2. The Relevant Art is 

Prior to the rise of the personal computer, computer 
users were limited to operating software that ran on 
large, mainframe computers using terminals that typi- 
cally included a keyboard for entering data and com- 20 
mands and a video display device (or printer) for viewing 
output. Although mainframes provided very powerful 
computing platforms, they suffered from serious draw- 
backs. In particular mainframes were expensive to in- 
stall and operate and they required all users to be con- 2S 
nected directly to the rr^inframe through a terminal, 
whk;h limited access to the mainframe for many people. 
Inaddltkxi, users had very limited control over their cofT>- 
puting environments, usually havrig to adapt their work 
styles and problems to suit the software and admin is- 30 
t ration of the mainframe computer. 

Beginning in the late 1 970's personal computers be- 
gan to overtake mainframes as the dominant computing 
platform for both personal, business, and scientifk; uses. 
For single users, personal computers often could pro- 35 
vide the same computing speed as the oWer main- 
frames that had to accommodate many processing jobs 
simultaneously. In addition software that ran on the per- 
sonal computers became more "user-friendly,' allowing 
computer users to adapt both the computer and the soft- 40 
ware to suit their particular computation needs. The re- 
lease from requiring a connectkxi from a terminal to a 
mainframe albwed personal computers to be located 
just about anywhere within an organ izatkxi or at home. 
This capability further assured the dominance of the per- *5 
sonal computer over the mainframe as computing pow- 
er could be located at sites where it was needed. No 
longer did users have to tailor their operations around 
large, expensive, finicky mainframe computing centers. 

As the computing power and data storage capaci- so 
ties of personal computers expkxied throughout the 
1 980's the dominance of the personal computer seemed 
to be assured. As the 1 980's drew to a close, however, 
a new phenomenon began to emerge which appears 
likely to overtake the personal computer revolution of ss 
the past two decades. Today, ever increasing numbers 
of personal computers are linked to each other through 
high speed data networks. The most popular network 



currently is the 'Internet* — the network comprising var- 
k5us business, academic, and personal computer sites 
across the gbbe. The popularity of the Internet, and, 
nrK>re particularly, that aspect of the Internet referred to 
as the "Workl Wide Web,' has prompted many organi- 
zations to form internal computer networks — the so- 
called "intranets." This interest in network computing 
has been sparked by a combination of high speed data 
networks and increasingly sophisticated network serv- 
ers, routers and other devrces which allow many inde- 
pendent personal computers to communicate efficiently. 

The attractiveness of the Wortd Wkie Web stems in 
part from its highly visual character, the same factor that 
played a large role in the rise of the personal computer 
and its dominance over the mainframe. Typk:ally, the 
World WkJe Web is organized into various "web sites" 
which typically comprise a server that transmits data to 
a client computer running a "browser." The browser is 
software that provides the user with a window arxl var- 
bus controls through whk:h data from the server can be 
viewed and navigated. A particularly useful feature of 
World Wide Web data is its ability to be linked through 
hypertext comnnands so that users can quk:kly navigate 
from one document to another and even from one web 
site to arK>ther through very simple intuitive commands 
such as the actrvatkxi of a nDouse button. Using the 
World Wide Web, users can view text, graphics and hear 
sounds from sites all over the globe. In addition users 
can also down toad new software, or software capable 
of modifying programs already installed on the dient 
computers. These same features available to users of 
the World Wide Web on the Intemet can also be provkJ- 
ed to users of a local network through an intranet. This 
capability has received increasing attention from nnany 
organ izatkxis as information useful to employees carry- 
ing out their assignments can be distributed quickly 
throughout the network to personal computers within the 
organ izatkxi. 

However, the use of modern networks for such a 
widespread distribution of infornnation and software 
points to a drawback regarding the highly decentralized 
nature of personal computers. Because users have so 
much control over their computing environments, and 
because of the need to maintain individual copies of 
software packages on individual computers, the man- 
agement of computer networks is becoming increasing- 
ly difficult. With so many remote computers connected 
to each other over computer networks, administrators 
are finding it difficult to insure that each user has a com- 
puter system that is configured to operate reliably and 
efficiently. Particular problems include the maintenance 
of current software revisions, nnodificatk)ns made to the 
operating-system and software by the users, the instal- 
lation of extraneous software on the local computer 
which is not required for performing the central tasks of 
the user, and the need to buy multiple copies of a single 
software package even if that package is used only 
sparingly. More important is the need to support soft- 
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ware that runs on different computer platforms, such as 
UNIX, Macintosh, arrd Windows, as several platforms 
are often used in organizations to perform different func- 
tions. For example, an organization might use Windows- 
based computers for running accounting software, Mac- 
intosh computers for graphics and design, and UNIX 
systems for network administration and high-end com- 
putation applications such as scientific or engineering 
calculations, or computer-aided design CCAD") or com- 
puter-aided engineering ("CAE") functions. This forces 
organizations to purchase multiple copies of the same 
software application to accommodate those uses that 
are common to all platforms (e.g., word-processing or 
database access). 

Thus, it would be of great benefit to computer users, 
and especially computer users within organizations in 
which multiple computer users are connected through a 
computer network, to provide methods and systems for 
disseminating both infornnation and software over the 
network so that the above-described problems associ- 
ated with highly decentralized computer networks can 
be mitigated. As will be described here and bek)w, the 
present invention meets these and other needs. 

SUMMARY OF THE INVENTION 

The present invent kxi addresses the above-de- 
scribed difficulties in managing software distributkxi 
across networked computer by providing, in one aspect, 
a method, system, and software for installing and oper- 
ating selected software applicatkxis on a client compu- 
ter that is in communication with a sender computer on 
a computer network. Using the methods, systems, and 
software described herein, software can be distributed 
to client computers without the installation and other 
management difficulties common with managing soft- 
ware on multiple computer systems. More importantly, 
the methods, systems, and apparatus provided by the 
present invention altow for the distributbn of software 
that is platform-independent; thereby freeing network 
and system administrators — and users — from the frus- 
trations and difficulties created by the need to manage 
various platform-dependent versions of software. 

In one aspect, the present invention provides a 
method for installing and operating a selected software 
application on a computer. According to one embodi- 
ment of the method of the invention, browser software 
is provided on the computer. The browser software is 
includes a browser user interface and is effective to 
identify and download selected software applications for 
execution. A desired software application is selected us- 
ing the browser. The browser user interface is then 
transmuted into the user interface of the desired appli- 
cation to allow operation of the downtoaded software ap- 
plication using the transmuted browser user interface. 

These, and other aspects and advantages of the 
present invention, will become apparent when the De- 
scription below is read in conjunction with the accompa- 



nying Drawings. 

BRIEF DESCRIPTION OF THE DRAWINGS 

5 Figure 1 illustrates a wide area computer network 
in which both computers and intranets are coupled by a 
computer network through the Internet. 

Figure 2 is a schematic representation of intranet 
such as illustrated in Figure 1 . 
10 Figures 3A and 3B illustrate the modification of a 
browser interlace in accordance with an embodiment of 
the present invention. Figure 3A illustrates a typical 
browser interface such as used to view text and graphics 
over the WorkJ Wide Web on the Internet or from a in- 
'5 tranet server Figure 38 represents a browser interface 
which has been rrodified using the methods and appa- 
ratus described herein to provkie a different functionality 
to the user. 

Figure 4 is a flowchart outlining one embodiment of 
the method of the present invention. 

Figure 5 is a flowchart illustrating in greater detail 
step 406 of Figure 4 according to one embodiment of 
the invention. 

Figure 6 is a schemata representaton of one em- 
bodiment of a method for transforming a browser inter- 
face according to the present invention. 

Figure 7 is a ftowchart illustrating step 41 2 of Figure 
4 in greater detail. 

Figure 8 is an illustratkxi of a browser interface 
which includes three frames" in whk:h text and graphk:s 
can be viewed independently. 

Figure 9 is a schematic representation of a method 
for rrxxJifying multiple frame browsers such as illustrated 
in Figure 8 according to one embodiment of the present 
invention. 

Figure 10 is a schematic representation of a com- 
puter system in accordance with the present invention. 



The present invention provides, in one embodi- 
ment, a method, apparatus, and software for dynami- 
cally nrxxJifying a browser interface to provide software 
functionalities that are distributed from a server across 
a network to a user working on a client computer whrch 
is coupled to the server through the computer network. 

An illustration of one network in accordance with the 
present invention is provided in Figure 1. Included in the 
network illustrated in Figure 1 are intranets 102 and 104 
and an individual computer shown at 106. The structure 
of intranets 102 and 104 is described in greater detail 
betow with respect to Figure 2. Both of the intranets and 
the computer are connected to the computer network 
through a variety of computer gateways CG/W"). In 
some embodiments, the computer network includes the 
Internet. Referring to Figure 1 more specifically, intranet 
102 is coupled with intranet 104 and computer 106 
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through the Internet which is shown generalty at 108. 
The connection between intranet 102 and Internet 108 
is provided first through a gateway 110 which is coupled 
with intranet 102 and a "backbone" or high capacity da- 
taline 112. Data from a high capacity line 112 is routed 
through gateway 114 through internet 108 which data 
passes through a second gateway 1 1 6 and into high ca- 
pacity dataline shown at 118. It will be appreciated by 
those of skill in the computer network arts that dataline 
118 can be the same as dataline 112 or may represent 
a separate backbone to whk:h varous other indivkJuats 
and networks are coupled. 

Data that travels from intranet 102 through the In- 
ternet artd over high speed dataline 1 1 8 passes through 
gateway 120 to intranet 104 or through gateway 124 to 
computer 106. Thus according to the illustrated embod- 
iment data can be passed among computer 1 06 intranet 
104 and intranet 102. In particular, the data may travel 
through the Internet 108 as just described, or may pass 
across the backbone 118 between the user and intranet 
104. In some embodiments intranet 104 and intranet 
102 can be coupled or directly through network config- 
uratkns known to those of skill in the art as "extranets. 
■ Extranets are network arrangements in whk;h a given 
network or individual is coupled with a renrK>te network 
through a dedcated data connect bn. This connection 
may include data that is routed through the Internet, as 
illustrated in Figure 1 , or may be a direct data feed, such 
as through an ISDN or T-1 dataline. \^rk>us configura- 
tions in additkxi to the methods and materials for estab- 
lishing such configurations will be apparent to those of 
skill in the computer network and tetecommuncations 
arts. 

One embodiment of an intranet, such as illustrated 
in Figure 1 at 102 or 104, is provkJed in Figure 2 at 200. 
Atypical intranet includes a server 202 which is coupled 
with clients 204 and 206. In additkxi the server can be 
coupled to other client computers such as shown at 21 0 
and 212 through a router, hub or similar data transfer 
device such as shown at 208. In addition, external users 
such as shown at 214 can be connected to the server 
either through a direct line or through the use of tele- 
phone lines using, a p., a nrxxJem or similar devk^e. In 
some cases, access to the intranet will be controlled to 
a high degree by a "firewair configuratkxi which is illus- 
trated by the dashed box 216. The establishment of 
communications from users external to the firewall, such 
as user 214, can be achieved by traversing a gateway 
whrch allows access to the protected server. Such a 
gateway is illustrated at 218. 

Typically the server provides data and software that 
is accessible to the various clients which are in commu- 
nicatbn with the server, either directly or through a de- 
vice such as a router. The construction, maintenance, 
and operation of the server, router, and various client 
machines will be well known to those of skill in the art. 
In particular, however, the server 208 will be configured 
to provide data that is compatible with browser software 



such as that used to view data on the Worki Wide Web 
as described above. Specifically, the data provided by 
the server will be in the form of pages of data that can 
be examined using typical browser software. In one em- 
5 bodiment, the server and clients are configured to ex- 
change not only data but computer software applica- 
tions and, more particularly, software in the form of 'ap- 
plets," such as those written in the Java™ programming 
language available from Sun Microsystems of Mountain 
View, California. The term "applet* as used herein refers 
to a software code that is executed in the context of soft- 
ware already running on the renrote computer. In one 
embodiment, the software in context with whch the ap- 
plet runs is the above-described browser software. Typ- 
cally, applets provide additkxial functkxia lilies to brows- 
er software by performing various computatkxial tasks 
which the browser software itself is not configured to 
pertorm. Thus, users who download applets can provkie 
the browser software with additkxial functkxialities that 
are not otherwise available to the browser software. 

According to one embodiment of the present inven- 
tion, the software applicafion, and, more partk;ularly the 
applet software, that is downloaded by the user func- 
tions to provide not only additkxial functionalities but is 
effective to modify the browser interface so that user is 
presented with, in effect, a different computer program. 
Thus, by downk>ading applets using the method and 
systems of the present invention, users can access soft- 
ware in a platform-independent fashkxi from a renDote 
server and operate that software as if rt were already 
installed on their local computer platform. Because ap- 
plets, such as Java™ applets, can functbn in a platform- 
independent manner, it will be appreciated that the 
present invention provides a way of distributing software 
in a platform independent manner that allows users to 
execute software without having that software installed 
on their local machines. The advantages provkied by 
such an arrangement include the ability of users to have 
access to the latest revisions of software without having 
that software installed on their kx^l machines, having 
access to software for only those perkxJs of time whk:h 
the user requires the services of that software thus 
avokJing the need to purchase expensive software that 
is used only sparingly, and to have access to highly spe- 
cialized software that may otherwise be available only 
on a specific and highly specialized computing plat- 
forms. 

However, it will also be appreciated that the above- 
described application and applet software used to mod- 
ify a browser to allow a user to run a variety of software 
applications over a network can be used with a single 
computer without connection to a computer network. In 
this case, the applicatbn software (or applet) used to 
modify the browser will reside in data storage coupled 
with the computer For example, large numbers of ap- 
plets that are effective to modify a browser's interface 
as described herein can be provided on a high-density 
storage medium, such as a CD-ROM. A user can then 



IS 



20 



25 



30 



35 



40 



45 



50 



7 

use a browser (which can also be provided on the CD- 
ROM) having links to each of the applets to easily 
browse the applet software available on the CD-ROM, 
select one or more desired applets, and run the applets 
directly through the browser interface as described be- 
low. Such an arrangement would obviate the need for 
the user to traverse labyrinthine file structures and 
launch and quit various applicattons. The browsing and 
control of the application(s) is performed within the con- 
text of the browser software. 

The operation of the invention is described in great- 
er detail with respect to Figures 3A and 3B. Figure 3A 
illustrates a browser interface such as any Java-capable 
browser available commercially. Such browsers include 
HotJava™ from JavaSoft™ of Cupertino, California, 
Netscape Navigator available from Netscape Commu- 
nications. Inc. of Mountain View, California and Micro- 
soft Explorer available from Microsoft Corporation of 
Redmond, Washington. 

Referring to Figure 3A. typical browser interfaces, 
such as that shown 300, include a window frame 302 
which encompasses a control region 304 and a viewing 
region 306. Control region 304 typically includes page 
controls 308 which allow users to navigate between var- 
ious pages of data provided by a server such as de- 
scribed above, a text entry window 310 for entering var- 
ious data required by the browser, e.g., UHL addresses 
or responses to queries, pull-down nr^enus which include 
a pop up bar shown at 312 which, when activated, dis- 
play a menu of options such as shown at 31 4, in addition 
to various other buttons that activate features and utili- 
ties which are shown generally at 316. Viewing region 
306 typically includes a viewing area 318 which viewing 
area provides a region into which text, hypertext links, 
and graphics are displayed to the user for examination. 
Often the viewing area includes a scroll bar such as 
shown at 320 which scroll bar further includes naviga- 
tion buttons such as shown at 322 and 324 and a 'thumb 
wheel" 326 all of which altow the user to scroll text up 
and down for examination. 

According to one embodiment of the present inven- 
tion, applets are provided which not only allow the user 
to execute specialized software different from the 
browser software with which the user activates the ap- 
plet, but which applet software transforms the browser 
interface to provide an interface that is specific for the 
functionality that the applet executes. An example of 
such a transformed interface is provided at 350 in Figure 
3B. As shown in Figure 3B, the transformation of the 
browser window provides a window which includes the 
original window frame 302 but which otherwise has 
completely changed the interface presented to the user 
The degree to which the browser's interface is changed, 
will, of course, depend on the nature of the application 
software. 

Thus, in the illustrated example the control surface 
and data windows have been modified to provide a more 
extensive control area 352 and a somewhat smaller and 
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fixed data viewing region 354. Control region 352 may 
contain a variety of data elements that may be the same 
as, or different from, ttiose of the original browser win- 
dow. For example, the control regkxi 352 in the illustrat- 
5 ed exemplary embodiment includes a variety of buttons 
356 and the data viewing region 354 includes a window 
356. It will be appreciated, of course, that the actual in- 
terface of both the browser and the applet will vary ac- 
cording to the features and functionalities provided for 
10 each type of software. Thus, in cases where database 
functionalities are provided by the applet the buttons 
356 may include commands such as sort, query gener- 
ation commands, buttons to allow the entry of new 
records and the deletion of old records, as well as but- 
15 tons to cause the termination of the executkxi of the ap- 
plet and the reconfiguration of the interface to return the 
user to the browser interface. In accordance with such 
an embodiment, the data presentation region 358 may 
provide nothing nrx>re than a window into which textural 
data is displayed in accordance with the commands pro- 
vided by the user through the control area 352. Of 
course, as mentioned above, the specific configurations 
will vary according to the functionalities and interface 
design of the particular browsers and applets being 
used and will be familiar to those of skill in the art. 

One embodiment of a method by which the afore- 
mentioned transformation is accomplished is shown at 
400 in Figure 4. As shown therein, the user first loads 
the browser software at step 402. In one embodiment, 
the browser software is installed on the kxal client ma- 
chine and is executed by the user directly from the client. 
Alternatively, the browser can be provided remotely 
across the network in which case the client machine is 
configured to respond nrx>re like a terminal than a star>d- 
atone computing platform. The implementatkxi of either 
configuration, and other configurations, will be apparent 
to those of skill in the art. Upon loading the browser, the 
user loads a web page whrch contains the desired applet 
to be executed at step 404. The loading of such web 
pages is performed using methods that are familiar to 
those of skill in the art. Upon loading the desired applet, 
the browser interface is transformed at step 406 such 
that a new interface is provided to the user whk:h in- 
cludes functionalities and displays that are consistent 
with the functionality of the applet as illustrated above 
with respect to Figures 3A and 3B. At step 408 the user 
operates the application, e.g,, the applet, using the 
transformed interface after which the user terminates 
the applet at step 410 from a command generated and 
passed to the applet through the rrKxJified browser in- 
terface. Finally, at step 412, the browser interface is re- 
turned to its original configuration from which the user 
may either select another applet to be loaded into the 
client computer, and which may transfomn the browser 
interlace again according to the sequence just de- 
scribed, or the user may terminate operatbn of the com- 
puter, or the user may execute software that is installed 
on the local machine. 
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Step 406 of Figure 4, the transformation of the 
browser interface into a new interface that functions in 
accordance with the applet, is illustrated in greater detail 
at 500 in Figure 5. At step 502 the applet which is now 
executing on the client computer, having been loaded 
from the remote server using standard techniques, ac- 
quires new properties settings that will be used to define 
the new functionalities to be presented in the trans- 
formed browser interface. The settings are typically 
stored on the server on which the applet is stored. How- 
ever, the settings may be provided at other locations, 
such as different sen/ers, or may be stored on the client 
computer system itself. At step 504 the applet commu- 
nicates the new properties settings to the browser as 
will be described in greater detail below. Upon the com- 
munication of the new properties settings to the browser, 
at step 506 the applet requests the browser to update 
Its interface using the new settings. At step 508 the 
browser transforms its interface as it updates its inter- 
face through the new properties settings that have been 
provided by the applet. This transformation relies on the 
same mechanisms used to construct the original brows- 
er interface and therefore will not be described in greater 
detail as such operations will be familiar of those of skill 
In the art. 

Typical properties settings include any setting that 
is used to define what Is displayed to the user In the 
browser window, including the functions that are initiat- 
ed when any displayed controls (e g,, buttons) are acti- 
vated by the user. Examples of such settings include 
those that provide menu bars, menu rlenns, buttons, sta- 
tus messages, grow and shrink boxes, window dimen- 
sions, window location, background cok^r, text labels, as 
well as the dimension, location, and presence of data 
fields. In addition, various page layout properties relat- 
ing to the Hypertext Mark-Up l-anguage ('HTML') such 
as font style, font size, typeface, font cokDr, spacing, 
kerning, and/or leading can be controlled using the prop- 
erties settings as well. It will be appreciated that chang- 
es made to the menu bar and menu items as described 
above can be used to add dynamically new functions 
using the remote code that Is provided by the applet. In 
additkxi, the buttons defined by the new properties set- 
tings can also be used to implement new functbns. 

The method by which the applet communk:ates the 
new settings to the browser, as called out in step 506 of 
Figure 5 are illustrated in greater detail with respect to 
Figure 6. According to one embodiment of the present 
invent bn. advantage is taken of the Java™ program- 
ming language's properties class characteristics. As will 
be familiar to those of skill in the art of programming in 
the Java™ language, the properties class is defined in 
part to act as a container that is configured to maintain 
a list of browser interface properties names and their 
associated values. Such a table is illustrated at 602 in 
Figure 6. The properties names and their associated 
values are provided in the regions indicated at 604 and 
606 for the browser properties settings that are provided 
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are originally and at 610 and 61 2 for the new properties 
settings that are provkied by the applet. According to 
one emlxxiiment of the invention each new instance of 
the properties class inherits values from the table from 

5 which the new properties class is created, i.e., the prop- 
erties class for the browser The applet provkJes the 
browser with the kx:atkxi of a new table that inherits its 
values from the original table for those items that are not 
changed. The new items provided by the applet replace 

10 the corresponding items of the original data used by the 
browser Thus, as shown in Figure 6. the central portkxi 
of the properties values of original table 602 are over- 
written by the new values of table 608 which Is down- 
toaded by the applet from the renx^e server Altema- 

15 tively, the applet can simply overwrite the values already 
provkjed In the properties table that is created by the 
browser when the browser Is initiated. In either case, 
either the applet or the browser shoukj be configured to 
retain a copy of the original browser Interface properties 

20 table so that the browser interface can be restored when 
the user exits the applet being used. 

Step 412 of Figure 4 in which the browser interface 
is restored fol towing these termination of the applet, is 
shown in greater detail at 700 in Figure 7. At step 702 

25 a determinatkxi is made as to whether the applet or the 
browser is responsible for maintaining a copy of the orig- 
inal browser interface settings. If the applet has the orig- 
inal settings, then those settings are communicated to 
the browser, e.g., using the methods just described with 

30 respect to Figure 6, or by redirecting the browser to a 
copy of the original properties table that has been placed 
in merrxjry at a kx:ation different from the modified orig- 
inal table. At step 706 the applet then sends a 'update 
interface* message to the browser to cause the browser 

35 to consult the copy of the original table to thereby restore 
its original settings and interface. Alternatively, if the 
browser is responsible for maintaining a copy of the orig- 
inal settings then the applet sends a "restore settings' 
message to the browser at step 708 which command is 

40 followed by the above-described "update interface" 
command to thereby cause the browser to restore Its 
original interface. In conjunct ton with this the applet 
ceases execution and the user Is returned to the brows- 
er Interface such as shown in Figure 3A from which the 

45 browser can select additional information through the 
browser 

In one embodiment, the present invention is config- 
ured to work with browsers that include one or more 
"frames." A browser including vartous frames is illustrat- 

50 ed at 800 in Figure 8. The interface typtoally includes a 
window frame 802 into which a variety of frames shown 
at 804, 806. 808. and 810 are provided. Frame 804. also 
commonly referred to as theO^ frame, is the base frame 
on top of which frames 806, 808, and 810 are provkJed. 

55 As wilt be familiar to those of skill in the art, various 
frames can perform a variety of independent functions. 
Thus, in the illustrated exemplary embodiment shown 
in Figure 8. frames 806 and 810 provide data viewing 
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regions 816 and 820 respectively which include scroll 
bars 812 and 814 with which the user can scroll through 
various data presented in each of the windows inde- 
pendently. Franne 808 by contrast provides a non-scroll- 
ing window 81 8. As mentioned above, the use of frames 5 
allows the user to review and examine information from 
independent sources through the action of independent 
frames. However, such a configuration provides certain 
difficurties with respect to the use of applets that modify 
the browser interface. In particular, since the user can io 
potentially activate different, independent applets 
through each of the available frames which can lead to 
conflicts in the appearance of the user interface. In gen- 
eral, the occurrence of such 'applet conflicts' should be 
avoided to provide the user with optimal operation of the 
interface. 

In one embodiment, the above described applet 
conflicts are avoided by configuring the interface to ex- 
ecute only one applet at a time. Thus, upon the selection 
of a particular applet in a particular frame, the remaining 
frames are deactivated, or, the ability to select an applet 
from the remaining frames is deactivated. Such a tech- 
nique will be recognized as providing extremely reliable 
control over applet conflicts although this approach may 
degrade somewhat the flexibility provided by the frame 2S 
technology. 

Alternatively, the browser can be configured to allow 
the user to identify a single "active" frame from which as 
applet can be launched. Only applets launched from ac- 
tive frames will be allowed to run, thus allowhg the user 30 
to select multiple applets but allowing the user only to 
execute only one applet at a time. Again, such a config- 
uration would provide the user with a high degree of con- 
trol over applet conflicts and would allow the user to ac- 
cess multiple applets and retain the use of multiple 3S 
frames. However, such an approach would tend to be 
highly nrxxJal; thus requiring the user to keep track of 
whk;h frame was active and would require the user to 
activate different frames in order to identify which ap- 
plets are available for executbn. 40 

A third alternative embodiment takes advantage of 
the inheritance structure provkJed by Java™ and de- 
scribed above with respect to Figure 6. According to this 
embodiment, a layered structure of replacement prop- 
erties settings tables is provided using the above-de- 45 
scribed inheritance mechanisms. An illustratk»i of such 
a structure is provided in Figure 9. As shown in the Fig- 
ure, a first table 902 including properties and values 904 
and 906 is provided for the 0**, or base, frames of the 
display (e.g., layer 804 of Figure 8). As each applet is 50 
activated though the various frames a replacement table 
is generated in accordance with the discussion provided 
above with respect to Figure 6. Thus, an applet activated 
in frame 806 might provide a modified properties set- 
tings table such as shown at 908 which includes differ- ss 
ent properties and corresponding values 910 and 912 
respectively. Upon activation of a second applet in frame 
808 a second replacement table 914, having properties 
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and values 916 and 918 respectively is provkJed. Finally, 
upon activation of a third applet in frame 810. a corre- 
sponding third replacement table 920 is provkJed with 
properties values 922 and corresponding data values 
924 provided. As illustrated in the Figure, each table 
takes advantage of the inheritance properties of the 
Java™ properties class to overwrite one or nrxjre seg- 
ments of data on the properties table instantiated previ- 
ously. Thus, the upper most table, which is associated 
with the iast-activated applet, ovenwites portions of the 
applets launched from the three previous frames. Sim- 
ilarly, the applet launched second-to-last is shown at 
91 4 artd overwrites portbns of the applet launched por- 
tions of the applet launched from the first frame as well 
as the interface defined by the 0** frame. Finally, the ap- 
plet launched from the first frame overwrites portions of 
the interface provided by the original interface. 

Such a structure as just described wouki be indic- 
ative of an applet execution hierarchy in which the most 
recently selected applet controls. Attematively, the 
same structure can be used but wherein the applets are 
executed in reverse order of selectkx^. In a second al- 
temative, the order of the properties tables is shuffled 
according to whk;h frame is being currently used. In a 
third alternative, the user is enabled to determine the 
prk)rity by which applets are executed. Because of the 
unique inheritance properties provkJed by the Java™ 
properties class as described above, great flexibility is 
provkJed in whk:h rules can be used to implement the 
interface provkled by the applets being executed. Thus, 
okJ properties values tables can be "shuffled" out and 
new tables shuffled in as applets are terminated and 
launched. 

It will be further appreciated by those of skill in the 
art that various security measures can be implemented 
in accordance with the present invention to provide pro- 
tection for data and the general operating environment 
at the client machine. In partcular, because an applet is 
an executing program, care must be taken in determin- 
ing the degree of access to which the applet has over 
the kx:al client system. Specifically, care should be pro- 
vkJed so that bask: f unctbnalities are retained across all 
user interfaces, such as the ability to quit the running 
applet. Other protected features include the control over 
the reading and writing of data from the client machine 
and the presentation of 'spurious* interfaces into whk;h 
an unsuspecting user might be instructed to enter sen- 
sitive information such as personal kJentification num- 
bers, encryption keys, or credit card numbers. In one 
emt)odiment, these concerns are addressed by provid- 
ing the user a mechanism for indicating to the applet the 
degree of control over which the applet will be provkied 
with respect to the local system. Thus, where applets 
are being provided from servers on highly secure net- 
works, such as an intranet protected by a fire-wall as 
described above with respect to Figure 2, the applets 
may be given a high degree of access to the local ma- 
chines because the possibility of an applet executing 
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damaging operatkxis is relatively low. Conversely, 
wtiere systems are being used to download and execute 
applets from servers over unsecured networks, such as 
from servers distributed across the Intemet. the applet 
may be provided with very few opportunities to modify 
the user's system. Still other mechanisnr^ for providing 
security will be apparent to those of skill In the art. 

Thus It will be seen from the foregoing that the 
present inventkxn overcomes the difTtcutties associated 
with diverse networked computer systems by provkJing 
a mechanism in whch software can be downk>aded to 
networked computers from a central sen/er and execut- 
ed through a standard browser interface in a platform- 
independent nwiner. Using the method system and 
software provkied by the present invention, users can 
select software from central sources and execute that 
software on their kx:al machines as if that software was 
installed originally on those kx^al machines. Thus, it will 
be appreciated that the present ffi vent ion largely over- 
comes the issues ot maintaining large numbers of cop- 
ies of software and appropriate software revisions 
across large divers computer networks as users can 
now download software from a single source and exe- 
cute the software for a limited period without making a 
great investment in the installation of that software. 

The present invention empkDys various process 
steps involving data stored in computer systems. These 
steps are those requiring physk:al manipulation of phys- 
k:al quantities. Usually, though not necessarily, these 
quantities take the form electrical or magnetic signals 
capable of being stored, transferred, combined, com- 
pared, and otherwise manipulated. It is sometimes con- 
venient, principally for reasons of common usage, to re- 
fer to these signals as bits, values, elements, variables, 
characters, data structures, or the like. It should be re- 
membered, however, that all of these and similar ternr^ 
are to be associated with the appropriate physical quan- 
tities and are merely convenient labels applied to these 
quantities. 

Further, the manipulations performed are often re- 
ferred to in terms such as identifying, running, or com- 
paring. In any of the operatkxis described herein that 
form part of the present invent bn these operatkxis are 
machine operations. Useful machines for performing 
the operations of the present inventk>n include general 
purpose digital computers or other similar devices. In all 
cases, there should be bome in mind the distinction be- 
tween the method of operations in operating a computer 
and the method of computation itself. The present in- 
vention relates to method steps for operating a compu- 
ter in processing electrical or other physical signals to 
generate other desired physical signals. 

The present invention also relates to an apparatus 
for performing these operations. This apparatus may be 
specially constructed for the required purposes, or it 
may be a general purpose computer selectively activat- 
ed or reconfigured by a computer program stored in the 
computer. The processes presented herein are not in- 



herently related to any parlcular computer or other ap- 
paratus. In particular, varbus general purpose ma- 
chines nnay be used with programs written in accord- 
ance with the teachings herein, or it may be more con- 

5 venient to const oict a more specialized apparatus to 
perform the required method steps. The required struc- 
ture for a variety of these machines will appear from the 
descriptkxi given below. 

In additkxi, the present invention further relates to 

^0 computer readable media which include program in- 
structkxis for performing various computer-implement- 
ed operatkxis. The media and program instructk>ns may 
be those specially designed and constructed for the pur- 
poses of the present invention, or they may be of the 

15 kind well known and available to those hiavtng skill in the 
computer software arts. Examples of computer reada- 
ble media include, but are not limited to, magnetk: media 
such as hard disks, fk>ppy disks, and magnetic tape; op- 
tical media such as CD-ROM disks; magneto-optical 

20 nnedia such as floptical disks; and hardware devices that 
are specially configured to store and perform program 
instructions, such as read-only merrtory devices (ROM) 
and random access memory (RAM). Examples of pro- 
gram instructions include both machine code, such as 

25 produced by a compiler, and files containing higher level 
code that can be executed by the computer using an 
interpreter. 

Figure 10 at 1000 shows a typical computer-based 
system ki accordance with the present inventkxi. The 

30 computer includes a processing unit 1002 effective for 
performing computations, such as. but not limited to. a 
central processing unit (CPU), or multiple processors in- 
cluding parallel processors or distributed processors. 
Processor 1002 is coupled with primary memory 1004 

35 such as random access memory (RAM) and read only 
memory. Typcally, RAM includes programming instruc- 
tions and data, including distributed objects and their as- 
sociated data and instructkxis, for processes currently 
operating on processor 1002. ROM typbally includes 

40 bask: operating instructions, data and objects used by 
the computer to perform its f unctk>ns. In additkxi, a sec- 
ondary storage devce 1008, such as a hard disk, CD 
ROM. magneto-optbal (floptical) drive, tape drive or the 
like, is coupled bkiirectionally with processor 1002. Sec- 

^ ondary storage device 1 008 generally includes additran- 
al programming instructions, data and objects that typ- 
k:ally are not in active use by the processor, although 
the address space may be accessed by the processor, 
e.g., for virtual memory or the like. The above described 

50 computer further includes an input/output source 1010 
that typically includes input media such as a keyboard, 
pointer devices (e.g., a mouse or stylus) and the like. 
Computer 1000 also includes a network connection 
1012. Additional mass storage devices (not shown) may 

55 also be connected to CPU 1002 through network con- 
nection 1012. It will be appreciated by those skilled in 
the art that the above described hardware and software 
elements, as well as networking devices, are of stand- 
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ard design and construction. 

The computer-ffnplemented methods described 
herein can be implemented using techniques and appa- 
ratus well-known in the computer science arts for exe- 
cuting computer program instructions on computer sys- 
tems. As used herein, the term 'computer system" is de- 
fined to include a processing device (such as a central 
processing unit, CPU) for processing data arrd instruc- 
tions that is coupled with one or more data storage de- 
vices for exchanging data and instructions with the 
processing unit, including, but not limited to, RAM, 
ROM, CD-ROM, hard disks, and the like. The data stor- 
age devices can be dedicated, Le., coupled directly with 
the processing unit, or remote, /.a, coupled with the 
processing unit, over a computer network. It will be ap- 
preciated that renrvDte data storage devices coupled to 
a processing unit over a computer network can be ca- 
pable of sending program instructkxis to a processing 
unit for executbn on a particular workstatkxi. In addilkxi, 
the processing device can be coupled with one or more 
addrtk)nal processing devices, either through the same 
physical structure (e.g., in a parallel processor), or over 
a computer network (e.g., a distributed processor ). The 
use of such remotely coupled data storage devices and 
processors will be familiar to those of skill in the compu- 
ter science arts. The term 'computer network" as used 
herein is defined to include a set of communk^tons 
channels interconnecting a set of computer systems 
that can communcate with each other. The communi- 
cations channels can include trartsmissksn media such 
as, but not limited to, twisted pair wires, coaxial cable, 
optical fibers, satellite links, or digital mk:rowave radio. 
The computer systems can be distributed over large, or 
"wide" areas (e.g.. over tens, hundreds, or thousands of 
miles, WAN), or kx3l area networks (e.g., over several 
feet to hundreds of feet, LAN). Furthermore, various ky 
cat- and wide-area networks can be combined to form 
aggregate networks of computer systems. One example 
of such a confederation of computer networks is the ■In- 
ternet." 

Although only a few embodiments of the present in- 
vention have been described, rt shoukj be understood 
that the present invention may be embodied in many 
other specific forms without departing from the spirit or 
scope of the present invention. By way of example, al- 
though the invention has been described in terms of a 
Java™ GUI and a Hot Java™ presentation engine, any 
suitable GUI and presentation engine which are plat- 
form-independent may be implemented. Therefore, the 
present examples are to be considered as illustrative 
and not restrictive, and the invention is not to be limited 
to the details given herein, but may be modified within 
the scope of the appended claims and their equivalents. 



Ctatms 

1. A method for installing and operating a selected 
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software applcatkxi on a computer, said software 
applicatkxi having a software application user inter- 
face, the method comprising the steps of: 

5 providing browser software on said computer, 

said browser software including a browser user 
interface and sakj browser software being ef- 
fective to kjentify said selected software appli- 
cation for execution; 

10 

selecting saki selected software applk:atkxi us- 
ing said browser; and 

transmuting said browser user interface into 
saki applk^atkxi user interface to albw thereby 
operatkxi of said selected software application 
using sakJ transmuted browser user interface. 

2. The method as recited in claim 1 further including 
20 the steps of terminating sakJ software application 
and restoring said browser user interface by trans- 
muting sakJ software applicatkxi user interlace into 
said browser user interface. 

25 3. The method as recited in any one of the preceding 
claims wherein saki software applk:ation is located 
on a server computer that is coupled with said com- 
puter through a computer network, said method fur- 
ther including the steps of: 

30 

establishing a data transfer link between sakJ 
server and said computer; and 

toading into the memory of said computer a set 
35 of properties settings corresponding to said 

software applcation user interface that are ef- 
fective to transmute saki browser user interface 
into said applk:atk)n user interface when said 
set of properties settings are exchanged for a 
40 set of properties settings corresponding to sakJ 

browser user interface. 

4. The method as recited in claim 3 further including 
the step of storing saki second set of properties set- 

45 tings. 

5. The method as recited in claim 4 wherein said step 
of storing said second set of properties settings is 
performed by one of said software application and 

50 saki browser software. 

6. The method as recited in any one of the preceding 
claims wherein said step of transmuting said brows- 
er user interface into said applicatk>n user interface 

55 comprises the step of instructing said browser soft- 
ware to update said browser user interface. 

7. The method as recited in any one of the preceding 
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claims wherein said browser user interface com- 
prises a plurality of frames, at least one of said 
frames being effective to identify and select inde- 
pendently a software application- 

8. The method as recited in claim 7 wherein only one 
of said frames is active and said step of selecting is 
performed for the currently active frame. 

9. The method as recited in claim 7 wherein only one 
of said frames is active and said step of transmuting 
is performed for a software application selected us- 
ing the currently active frame. 

10. The method as recited in claim 7 wherein a plurality 
of said frames is active simultaneously and said 
step of transmuting is performed for each frame in 
which a software application is executing. 

11. The method as recited in any one of the preceding 
claims wherein said software application comprises 
an applet. 

12. The method as recited in claim 11 , wherein said ap- 
plet is a Java^ applet. 

13. The method as recited in claim 1 1 wherein said soft- 
ware application comprises a Java^ applet and 
said step of transmitting said selected software ap- 
plication comprises loading a first set of properties 
settings corresponding to said browser user inter- 
face and a second set of properties settings that are 
effective to transmute said browser user interface 
into said software application user interface when 
said first set of properties settings are exchanged 
for said second set of properties settings, said first 
set of properties settings and said second set of 
properties settings each including a table of user in- 
terface attributes and attribute values correspond- 
ing to said attributes. 

14. The method as recited in claim 13, wherein said 
browser user interface comprises a plurality of 
frames including a base frame, at least one of said 
plurality of frames being effective to identify and se- 
lect independently a software application from said 
server. 

15. A method for installing and operating a selected 
software application on a client computer, said soft- 
ware application having a software application user 
interface and said software application residing on 
a server computer that is coupled with said client 
computer through a computer network, the method 
comprising the steps of: 

providing browser software on said client com- 
puter, said browser software including a brows- 



er user interface and said browser software be- 
ing effective to identify and download a select- 
ed applet onto said client computer for execu- 
tion; 

5 

establishing a data transfer communication link 
between saki client computer and said server 
computer across said computer network; 

10 selecting said selected applet using said 

browser; 

transmitting said selected applet from said 
server computer to said client computer across 
15 sakJ computer network; and 

transmuting said browser user interface into 
sakI applk^atkxi user interface to alk>w thereby 
operation of said selected software application 
20 using sakJ transmuted browser user interface. 

16. The method as recited in claim 1 5 wherein sakJ ap- 
plet is a Java™ applet, and said step of transmitting 
saki selected software application comprises k>ad- 

25 jng a first set of properties settings corresponding 
to said browser user interface and a secorxJ set of 
properties settings that are effective to transmute 
sakJ browser user interface into sakJ software ap- 
plication user interface when said first set of prop- 
^ erties settings are exchanged for sakJ second set 
of properties settings, said first set of properties set- 
tings and sakJ second set of properties settings 
each including a table of user interface attributes 
and attribute values corresponding to said at- 
35 tributes. 

17. The method as recited in claim 16 wherein said first 
set of properties settings and sakJ second set of 
properties settings each comprise software objects 

40 such that the software object defining saki second 
set of properties settings has an inheritance rela- 
tionship with the software object defining sakI first 
set of properties settings, wherein the default val- 
ues of said second set of properties settings are the 
45 properties settings of said first set of properties set- 
ting parameters, and said step of transmuting said 
browser software user interface into sakJ software 
application user interface includes substituting se- 
lected default values of said first set of properties 
50 settings with properties settings corresponding to 
sakJ software application user interface. 

18. The method as recited in claim 17 further including 
the step of storing said second set of properties set- 

55 tings, wherein said step of storing said second set 
of properties settings is performed by one of said 
applet and said browser software. 
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1 9. The method as recited in claim 1 7 wherein said step 
of transmuting said browser user interface into said 
software application user interface comprises the 
step of instructing said browser software to update 
said browser user interface such that said browser 
user interface is reconstructed using said first set of 
properties setting values to produce thereby said 
software application user interface. 

20. A computer system for executing a selected soft- 
ware application on a computer, said software ap- 
plication having a software application user inter- 
face, said computer system comprising: a computer 
coupled with at least one memory device which 
holds therein browser software irtcluding a browser 
user interface, said browser software being effec- 
tive to identify a selected software application for 
execution by said computer, said selected software 
application being effective to transmute said brows- 
er user ffiterface into said software application user 
interface to allow thereby operation of said selected 
software application using said transmuted browser 
user interface when said software application is ex- 
ecuted by said computer. 

21 . The computer system as recited in claim 20 wherein 
said software application is stored on a second 
menrory device coupled with said computer, said 
menr»ory device coupled with said computer in- 
cludes a first set of properties settings correspond- 
ing to said browser user interface, and said second 
menrory device holds a second set of properties 
settings that are effective to transmute said browser 
user interface into said software application user in- 
terface when said second set of properties settings 
are exchanged for said first set of properties set- 
tings, wherein each of said first set of properties set- 
tings and said second set of properties settings in- 
clude a table of user interface attributes and at- 
tribute values corresponding to said user interface 
attributes. 

22. The computer system as recited in either claim 20 
or claim 21 wherein said software application com- 
prises an applet a Java™ applet. 

23. The computer system as recited in either claim 21 
or claim 22 wherein said first set of properties set- 
lings and said second set of properties settings 
each comprise software objects such that the soft- 
ware object defining said second set of properties 
settings has an inheritance relationship with the 
software object defining said first set of properties 
settings, wherein the default values of said second 
set of properties settings are the properties settings 
of said first set of properties setting parameters, and 
said selected software application is configured to 
substitute selected default values of said second 



set of properties settings with properties settings 
corresponding to said selected software application 
user interface when said selected software applica- 
tion transmutes said browser user interface into 
^ said software application user interface. 

24. The computer system as recited in any one of 
clainrts 20-23 wherein said browser user Interface 
comprises a plurality of frames, at least one of said 

JO frames being effective to identify and select inde- 
pendently a software application from said server. 

25. The computer system of claim 24, wherein only one 
of said frames is active and said step of selecting is 

J5 performed for the currently active frame. 

26. The computer system of claim 24, wherein only one 
of said frames is active and said step of transmuting 
is performed for a software application selected us- 

20 ing the currently active frame. 

27. A computer-readable medium comprising compu- 
ter-readable program code devices configured to 
cause a computer to: 

25 

display a browser user interface, said browser 
user interface being effective to control browser 
software operating on said computer, 

30 display at least one software application stored 

on memory coupled with said computer using 
said browser user interface, said software ap- 
plication having an application user interface; 

35 identify a selected software application from 

memory for transfer to said computer; and 

cause the transfer of said selected software ap- 
plication from said memory to said computer 
40 such that said transferred selected software ap- 

plication causes a transmuting of said browser 
user interface into said application user inter- 
face whereby said application can be controlled 
from said transmuted browser user interface 
45 when said application is being executed by said 

computer. 

28. The computer readable medium as recited in claim 
27 including computer-readable program code de- 

so vices defining: 

a first set of properties settings corresponding 
to said browser user interface; and 

55 a second set of properties settings that are ef- 

fective to transmute said browser user interface 
into said software application user interface 
when said second set of properties settings are 
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exchanged for said first set of properties set- 
tings; 

wherein each of said first set of properties set- 
tings and said second set of properties setting s 
include a table of user interface attributes and 
attribute values corresponding to said user in- 
terface attrtoutes. 
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